# Seek help early and not wait till the final 45 minutes of the lab class

The problems commonly encountered by students in lab 3, 4, 5 when using the Vivado software are documented here.

Students may use this as a "Self Help" guide to troubleshoot.

# General problems in Lab 3, 4 and 5

|    | Wrong action                      | Correct action                                                       |
|----|-----------------------------------|----------------------------------------------------------------------|
| 1  | Accidentally use earlier files    | <b>Delete</b> any existing folder named Lab3, Lab4                   |
|    | created by other students         | or Lab5 from <b>Drive D</b>                                          |
| 2  | Did not have all the required     | Check that you have all the required                                 |
|    | files for the project             | <ul> <li>design files (filename.v)</li> </ul>                        |
|    |                                   | <ul><li>simulation file (filename_tb.v)</li></ul>                    |
|    |                                   | <ul> <li>and constraint file (filename.xdc)</li> </ul>               |
|    |                                   | • in the <b>same</b> directory/folder (e.g. Lab3)                    |
| 3  | The required files are in         | • Create a directory (e.g. Lab3) in <b>Drive D</b>                   |
|    | different folders                 | copy the required files to this new                                  |
|    |                                   | directory/folder (e.g. Lab3)                                         |
| 4  | Unable to select the required     | Check that you are using the correct software                        |
|    | FPGA part                         | version: Vivado 2022.2                                               |
| 5  | Wrong FPGA part selected          | Go to Project Summary to select the                                  |
|    |                                   | correct FPGA part                                                    |
| 6  | The project is open in Drive C    | <ul> <li>Create a directory (e.g. Lab3) in <b>Drive D</b></li> </ul> |
|    |                                   | <ul> <li>copy the required files to this new</li> </ul>              |
|    |                                   | directory/folder (e.g. Lab3)                                         |
|    |                                   | Open the project and select <b>Drive D</b>                           |
| 7  | A module is missing               | Check that each module is contained                                  |
|    |                                   | within a single .v file                                              |
|    |                                   | The module should have the same name                                 |
|    |                                   | as the filename                                                      |
|    |                                   | Check that the .v file is added to the project                       |
| 0  | Mara a secondada in cabacaban     | as a <b>design</b> source                                            |
| 8  | Wrong module is set as top        | Right click on the correct module to set it  as the term and the     |
|    | module                            | as the <b>top module</b>                                             |
| 9  | filename_tb.v file added as a     | Right click to remove the file                                       |
| 40 | design file or constraint file    | add the file as a <b>simulation</b> source                           |
| 10 | filename.xdc file added as a      | Right click to remove the file                                       |
|    | design file or simulation file    | add the file as a constraint source                                  |
| 11 | filename.v file added as a        | Right click to remove the file                                       |
|    | constraint file or testbench file | add the file as a <b>design</b> source                               |
| 12 | filename.xdc file not added to    | Constraint file is required for                                      |
|    | project                           | implementation                                                       |
|    |                                   | Add the file as a <b>constraint</b> source                           |

| 13 | More than one <i>filename</i> .xdc files are added to project                          | <ul> <li>A circuit only has one constraint file</li> <li>Right click to remove the extra constraint file</li> </ul>                                                                   |
|----|----------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14 | Unable to program hardware                                                             | Slide the FPGA board power switch to ON                                                                                                                                               |
| 15 | Modify design file but no observable difference in simulation or implementation result | <ul> <li>Do not open more than one instance of<br/>Vivado</li> <li>Keep only one instance – with the design<br/>file that you have modified – and close all<br/>the others</li> </ul> |

## Common Problems in Lab 3

|   | Wrong action                                                                  | Correct action                                                                                                                                                                                                                                                                                                                                                              |
|---|-------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 | Syntax error: Did not enter semicolon after each assign statement             | Make sure each assign statement ends with a semicolon (;)                                                                                                                                                                                                                                                                                                                   |
| 2 | Entered one or more incorrect<br>Boolean expressions for<br>segment c, d or f | <ul> <li>Look at the simulation result for seg_L[6:0]</li> <li>Compare with the expected result of seg_L[6:0] given in the Vivado guide</li> <li>Deduce the incorrect segment by looking at the bit position that has error</li> <li>Seg_L[2] is segment c</li> <li>Seg_L[3] is segment d</li> <li>Seg_L[5] is segment f</li> <li>Correct the segment expression</li> </ul> |

## Common Problems in Lab 4

|   | Wrong action                     | Correct action                                                 |
|---|----------------------------------|----------------------------------------------------------------|
| 1 | vaddflow only has inputs but no  | Make sure vaddflow has these outputs:                          |
|   | outputs declared                 | • seg_L                                                        |
|   |                                  | • oflow                                                        |
| 2 | [0:0] oflow declared             | Do not declare size for a single-bit signal                    |
| 3 | [0:6] seg_L declared             | should be [6:0] seg_L                                          |
| 4 | Wrong size declared for inputs a | Inputs a, b are 4-bit signals                                  |
|   | and b of vaddflow                |                                                                |
| 5 | oflow not assigned a value       | oflow is the carry output of (a+b)                             |
| 6 | Missing endcase                  | Make sure to end a case statement using the                    |
|   |                                  | keyword <b>endcase</b>                                         |
| 7 | seg_L wrongly declared as reg    | <ul> <li>seg_L is assigned a value by instantiating</li> </ul> |
|   | in module vaddflow               | vsevenseg                                                      |
|   |                                  | <ul> <li>seg_L should not be declared reg</li> </ul>           |
| 8 | seg_L is not declared as reg in  | seg_L is assigned a value within an always                     |
|   | module vsevenseg                 | block                                                          |

|   |                              | seg_L should be declared reg              |
|---|------------------------------|-------------------------------------------|
| 9 | vsevenseg wrongly set as top | right click to set vaddflow as top module |
|   | module                       |                                           |

### Common Problems in Lab 5

|   | Wrong action                  | Correct action                                                                                      |
|---|-------------------------------|-----------------------------------------------------------------------------------------------------|
| 1 | [0:0] clk, rst declared       | Do not declare size for a single-bit signal                                                         |
| 2 | value not declared            | <ul> <li>value is a multi-bit signal (aka vector or bus)</li> </ul>                                 |
|   |                               | Its size must be correctly declared                                                                 |
| 3 | Wrong clk used for scroll     | Look carefully at Figure 1 of the lab manual to see the correct clock signal that scroll should use |
| 4 | Wrong inputs given to convert | Check that the correct inputs are given to each of the 4 instances of convert                       |

Consider the following options when your circuit does not work correctly:

- Look at the sources of other students whose circuits are working to compare and identify what your circuit design might have been done differently
- 2. Ask the lab supervisor or graduate student for assistance. Note that they may give you pointers but are not obliged to make your circuit work.
- 3. When nothing seems wrong with your sources (i.e. your circuit design) but there are still problems with Vivado, close it. Create a new folder with a different name (e.g. lab4a), copy all the essential source files into it. Start a new Vivado project pointing to this new folder, add all the needed sources correctly. Run implementation again. On many past occasions the problems got resolved by itself this way.
- 4. When all else have failed, you may repeat item (3) above on a different PC.